<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <canvas width="400" height="400"></canvas>

    <style>
        canvas{
            /* canvas 的宽高，不能在CSS 里面指定 */
            /* width: 200px;
            height: 200px; */
            border: 1px solid red;
        }
    </style>

    <script>
        let el = document.querySelector("canvas");

        let ctx = el.getContext("2d");

        // 黄色大三角
        ctx.strokeStyle = "yellow";
        ctx.moveTo(0, 0);
        ctx.lineTo(100, 100);
        ctx.lineTo(0, 200);
        ctx.stroke();
        ctx.fillStyle = "yellow";
        ctx.fill();

        // 绿色大三角
        ctx.beginPath();
        ctx.moveTo(0, 0);
        ctx.lineTo(200, 0);
        ctx.lineTo(100, 100); // 6
        ctx.lineTo(0, 0); // 6
        ctx.strokeStyle = "green";
        ctx.stroke();
        ctx.fillStyle = "green";
        ctx.fill();
 
        // 右三角形
        ctx.beginPath();
        ctx.moveTo(200, 0); // 3
        ctx.lineTo(200, 100); // 7
        ctx.lineTo(150, 50); // 9
        ctx.lineTo(200, 0); // 3
        ctx.strokeStyle = "blue";
        ctx.stroke();
        ctx.fillStyle = "blue";
        ctx.fill();

        // 红矩形
        ctx.beginPath();
        ctx.moveTo(150, 50); // 9
        ctx.lineTo(200, 100); // 7
        ctx.lineTo(150, 150); // 11
        ctx.lineTo(100, 100); // 6
        ctx.strokeStyle = "red";
        ctx.stroke();
        ctx.fillStyle = "red";
        ctx.fill();

        // 三角形
        ctx.beginPath();
        ctx.moveTo(100, 100); // 6
        ctx.lineTo(150, 150); // 11
        ctx.lineTo(50, 150); // 10
        ctx.lineTo(100, 100); // 10
        ctx.strokeStyle = "lightblue";
        ctx.stroke();
        ctx.fillStyle = "lightblue";
        ctx.fill();

        // 平行四边形
        ctx.beginPath();
        ctx.moveTo(50, 150); // 10
        ctx.lineTo(150, 150); // 11
        ctx.lineTo(100, 200); // 8
        ctx.lineTo(0, 200); // 5
        ctx.lineTo(50, 150); // 10
        ctx.strokeStyle = "rgb(128,0,128)";
        ctx.stroke();
        ctx.fillStyle = "rgb(128,0,128)";
        ctx.fill();

        // 三角形
        ctx.beginPath();    //  重新 渲染（上下文）
        ctx.moveTo(200, 100); // 7
        ctx.lineTo(200, 200); // 4
        ctx.lineTo(100, 200); // 8
        ctx.strokeStyle = "rgb(255,165,0)";  // 设置颜色 
        ctx.stroke(); // 填充 （边框）
        ctx.fillStyle = "rgb(255,165,0)";
        ctx.fill();

        // ctx.beginPath();    // 开始
        // ctx.closePath(); // 闭合



    </script>
</body>
</html>